package com.arsn.myf.system.mapper;

import com.arsn.myf.common.node.MenuTreeNode;
import com.arsn.myf.common.node.TreeNode;
import com.arsn.myf.system.entity.Menu;
import com.arsn.myf.system.entity.User;
import com.arsn.myf.system.vo.MenuVO;
import com.baomidou.mybatisplus.annotation.SqlParser;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import org.apache.ibatis.annotations.MapKey;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import java.util.List;
import java.util.Map;

/**
 * 菜单mapper 映射层
 * @author zhongrj
 * @time 2021-9-10
 */
@Mapper
public interface MenuMapper extends BaseMapper<Menu> {
    /**
     * 自定义菜单分页数据
     * @param page
     * @param menu
     * @return
     */
    @MapKey(value = "id")
    @SqlParser(filter=true)
    Map<Long, MenuVO> selectPageMenuList(@Param("menu") MenuVO menu);

    /**
     * 登录完成获取菜单列表
     * @param roleIdList 角色
     * @param menu 菜单实体
     * @return
     */
    @MapKey(value = "id")
    @SqlParser(filter=true)
    Map<Long, MenuTreeNode> getMenu(@Param("roleIdList") List<String> roleIdList, @Param("menu") MenuVO menu);

    /**
     * 获取菜单列表
     * @param menu 菜单实体
     * @return
     */
    @MapKey(value = "id")
    @SqlParser(filter=true)
    Map<Long,TreeNode> getMenuTree(@Param("menu") MenuVO menu);

    /**
     * 根据角色id 查询当前角色拥有的菜单集合id
     * @param roleId 角色id
     * @return
     */
    List<String> getMenuListByRoleId(@Param("roleId") String roleId);
}
